// RAP [rh] package org.eclipse.ui.keys disabled ///******************************************************************************* // * Copyright (c) 2000, 2006 IBM Corporation and others. // * All rights reserved. This program and the accompanying materials // * are made available under the terms of the Eclipse Public License v1.0 // * which accompanies this distribution, and is available at // * http://www.eclipse.org/legal/epl-v10.html // * // * Contributors: // * IBM Corporation - initial API and implementation // *******************************************************************************/ // //package org.eclipse.ui.keys; // //import java.util.ArrayList; //import java.util.Arrays; //import java.util.Collections; //import java.util.List; //import java.util.StringTokenizer; // //import org.eclipse.ui.internal.util.Util; // ///** // * <p> // * A <code>KeySequence</code> is defined as a list of zero or more // * <code>KeyStrokes</code>, with the stipulation that all // * <code>KeyStroke</code> objects must be complete, save for the last one, // * whose completeness is optional. A <code>KeySequence</code> is said to be // * complete if all of its <code>KeyStroke</code> objects are complete. // * </p> // * <p> // * All <code>KeySequence</code> objects have a formal string representation // * available via the <code>toString()</code> method. There are a number of // * methods to get instances of <code>KeySequence</code> objects, including one // * which can parse this formal string representation. // * </p> // * <p> // * All <code>KeySequence</code> objects, via the <code>format()</code> // * method, provide a version of their formal string representation translated by // * platform and locale, suitable for display to a user. // * </p> // * <p> // * <code>KeySequence</code> objects are immutable. Clients are not permitted // * to extend this class. // * </p> // * // * @deprecated Please use org.eclipse.jface.bindings.keys.KeySequence // * @since 3.0 // */ //public final class KeySequence implements Comparable { // // /** // * The delimiter between multiple key strokes in a single key sequence -- // * expressed in the formal key stroke grammar. This is not to be displayed // * to the user. It is only intended as an internal representation. // */ // public final static String KEY_STROKE_DELIMITER = "\u0020"; //$NON-NLS-1$ // // /** // * An empty key sequence instance for use by everyone. // */ // private final static KeySequence EMPTY_KEY_SEQUENCE = new KeySequence( // Collections.EMPTY_LIST); // // /** // * An internal constant used only in this object's hash code algorithm. // */ // private final static int HASH_FACTOR = 89; // // /** // * An internal constant used only in this object's hash code algorithm. // */ // private final static int HASH_INITIAL = KeySequence.class.getName() // .hashCode(); // // /** // * The set of delimiters for <code>KeyStroke</code> objects allowed // * during parsing of the formal string representation. // */ // public final static String KEY_STROKE_DELIMITERS = KEY_STROKE_DELIMITER // + "\b\r\u007F\u001B\f\n\0\t\u000B"; //$NON-NLS-1$ // // /** // * Gets an instance of <code>KeySequence</code>. // * // * @return a key sequence. This key sequence will have no key strokes. // * Guaranteed not to be <code>null</code>. // */ // public static KeySequence getInstance() { // return EMPTY_KEY_SEQUENCE; // } // // /** // * Gets an instance of <code>KeySequence</code> given a key sequence and // * a key stroke. // * // * @param keySequence // * a key sequence. Must not be <code>null</code>. // * @param keyStroke // * a key stroke. Must not be <code>null</code>. // * @return a key sequence that is equal to the given key sequence with the // * given key stroke appended to the end. Guaranteed not to be // * <code>null</code>. // */ // public static KeySequence getInstance(KeySequence keySequence, // KeyStroke keyStroke) { // if (keySequence == null || keyStroke == null) { // throw new NullPointerException(); // } // // List keyStrokes = new ArrayList(keySequence.getKeyStrokes()); // keyStrokes.add(keyStroke); // return new KeySequence(keyStrokes); // } // // /** // * Gets an instance of <code>KeySequence</code> given a single key // * stroke. // * // * @param keyStroke // * a single key stroke. Must not be <code>null</code>. // * @return a key sequence. Guaranteed not to be <code>null</code>. // */ // public static KeySequence getInstance(KeyStroke keyStroke) { // return new KeySequence(Collections.singletonList(keyStroke)); // } // // /** // * Gets an instance of <code>KeySequence</code> given an array of key // * strokes. // * // * @param keyStrokes // * the array of key strokes. This array may be empty, but it // * must not be <code>null</code>. This array must not contain // * <code>null</code> elements. // * @return a key sequence. Guaranteed not to be <code>null</code>. // */ // public static KeySequence getInstance(KeyStroke[] keyStrokes) { // return new KeySequence(Arrays.asList(keyStrokes)); // } // // /** // * Gets an instance of <code>KeySequence</code> given a list of key // * strokes. // * // * @param keyStrokes // * the list of key strokes. This list may be empty, but it must // * not be <code>null</code>. If this list is not empty, it // * must only contain instances of <code>KeyStroke</code>. // * @return a key sequence. Guaranteed not to be <code>null</code>. // */ // public static KeySequence getInstance(List keyStrokes) { // return new KeySequence(keyStrokes); // } // // /** // * Gets an instance of <code>KeySequence</code> given a new-style key // * sequence. // * // * @param newKeySequence // * The new-style key sequence to convert into a legacy key // * sequence; must not be <code>null</code>. // * @return a key sequence; never <code>null</code>. // */ // public static final KeySequence getInstance( // final org.eclipse.jface.bindings.keys.KeySequence newKeySequence) { // final org.eclipse.jface.bindings.keys.KeyStroke[] newKeyStrokes = newKeySequence // .getKeyStrokes(); // final int newKeyStrokesCount = newKeyStrokes.length; // final List legacyKeyStrokes = new ArrayList(newKeyStrokesCount); // // for (int i = 0; i < newKeyStrokesCount; i++) { // final org.eclipse.jface.bindings.keys.KeyStroke newKeyStroke = newKeyStrokes[i]; // legacyKeyStrokes.add(SWTKeySupport // .convertAcceleratorToKeyStroke(newKeyStroke // .getModifierKeys() // | newKeyStroke.getNaturalKey())); // } // // return new KeySequence(legacyKeyStrokes); // } // // /** // * Gets an instance of <code>KeySequence</code> by parsing a given a // * formal string representation. // * // * @param string // * the formal string representation to parse. // * @return a key sequence. Guaranteed not to be <code>null</code>. // * @throws ParseException // * if the given formal string representation could not be // * parsed to a valid key sequence. // */ // public static KeySequence getInstance(String string) throws ParseException { // if (string == null) { // throw new NullPointerException(); // } // // List keyStrokes = new ArrayList(); // StringTokenizer stringTokenizer = new StringTokenizer(string, // KEY_STROKE_DELIMITERS); // // while (stringTokenizer.hasMoreTokens()) { // keyStrokes.add(KeyStroke.getInstance(stringTokenizer.nextToken())); // } // // try { // return new KeySequence(keyStrokes); // } catch (Throwable t) { // throw new ParseException( // "Could not construct key sequence with these key strokes: " //$NON-NLS-1$ // + keyStrokes); // } // } // // /** // * The cached hash code for this object. Because <code>KeySequence</code> // * objects are immutable, their hash codes need only to be computed once. // * After the first call to <code>hashCode()</code>, the computed value // * is cached here for all subsequent calls. // */ // private transient int hashCode; // // /** // * A flag to determine if the <code>hashCode</code> field has already // * been computed. // */ // private transient boolean hashCodeComputed; // // /** // * The list of key strokes for this key sequence. // */ // private List keyStrokes; // // /** // * Constructs an instance of <code>KeySequence</code> given a list of key // * strokes. // * // * @param keyStrokes // * the list of key strokes. This list may be empty, but it must // * not be <code>null</code>. If this list is not empty, it // * must only contain instances of <code>KeyStroke</code>. // */ // private KeySequence(List keyStrokes) { // this.keyStrokes = Util.safeCopy(keyStrokes, KeyStroke.class); // // for (int i = 0; i < this.keyStrokes.size() - 1; i++) { // KeyStroke keyStroke = (KeyStroke) this.keyStrokes.get(i); // // if (!keyStroke.isComplete()) { // throw new IllegalArgumentException(); // } // } // } // // /** // * @see java.lang.Object#equals(java.lang.Object) // */ // public int compareTo(Object object) { // KeySequence castedObject = (KeySequence) object; // int compareTo = Util.compare(keyStrokes, castedObject.keyStrokes); // return compareTo; // } // // /** // * Returns whether or not this key sequence ends with the given key // * sequence. // * // * @param keySequence // * a key sequence. Must not be <code>null</code>. // * @param equals // * whether or not an identical key sequence should be considered // * as a possible match. // * @return <code>true</code>, iff the given key sequence ends with this // * key sequence. // */ // public boolean endsWith(KeySequence keySequence, boolean equals) { // if (keySequence == null) { // throw new NullPointerException(); // } // // return Util.endsWith(keyStrokes, keySequence.keyStrokes, equals); // } // // /** // * @see java.lang.Object#equals(java.lang.Object) // */ // public boolean equals(Object object) { // if (!(object instanceof KeySequence)) { // return false; // } // // return keyStrokes.equals(((KeySequence) object).keyStrokes); // } // // /** // * Formats this key sequence into the current default look. // * // * @return A string representation for this key sequence using the default // * look; never <code>null</code>. // */ // public String format() { // return KeyFormatterFactory.getDefault().format(this); // } // // /** // * Returns the list of key strokes for this key sequence. // * // * @return the list of key strokes keys. This list may be empty, but is // * guaranteed not to be <code>null</code>. If this list is not // * empty, it is guaranteed to only contain instances of <code>KeyStroke</code>. // */ // public List getKeyStrokes() { // return keyStrokes; // } // // /** // * @see java.lang.Object#hashCode() // */ // public int hashCode() { // if (!hashCodeComputed) { // hashCode = HASH_INITIAL; // hashCode = hashCode * HASH_FACTOR + keyStrokes.hashCode(); // hashCodeComputed = true; // } // // return hashCode; // } // // /** // * Returns whether or not this key sequence is complete. Key sequences are // * complete iff all of their key strokes are complete. // * // * @return <code>true</code>, iff the key sequence is complete. // */ // public boolean isComplete() { // return keyStrokes.isEmpty() // || ((KeyStroke) keyStrokes.get(keyStrokes.size() - 1)) // .isComplete(); // } // // /** // * Returns whether or not this key sequence is empty. Key sequences are // * complete iff they have no key strokes. // * // * @return <code>true</code>, iff the key sequence is empty. // */ // public boolean isEmpty() { // return keyStrokes.isEmpty(); // } // // /** // * Returns whether or not this key sequence starts with the given key // * sequence. // * // * @param keySequence // * a key sequence. Must not be <code>null</code>. // * @param equals // * whether or not an identical key sequence should be considered // * as a possible match. // * @return <code>true</code>, iff the given key sequence starts with // * this key sequence. // */ // public boolean startsWith(KeySequence keySequence, boolean equals) { // if (keySequence == null) { // throw new NullPointerException(); // } // // return Util.startsWith(keyStrokes, keySequence.keyStrokes, equals); // } // // /** // * Returns the formal string representation for this key sequence. // * // * @return The formal string representation for this key sequence. // * Guaranteed not to be <code>null</code>. // * @see java.lang.Object#toString() // */ // public String toString() { // return KeyFormatterFactory.getFormalKeyFormatter().format(this); // } //}